package com.sky.mapper;

import com.sky.entity.SetmealDish;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper
public interface SetmealDishMapper {

    /**
     * 根据菜品id查找是否有相关联的套餐
     * @param ids
     * @return
     */
    int countOfSelectByDishId(List<Long> ids);

    /**
     * 插入菜品与套餐信息
     * @param setmealDish
     */
    @Insert("insert into setmeal_dish(setmeal_id, dish_id, name, price, copies) values " +
            "(#{setmealId}, #{dishId}, #{name}, #{price}, #{copies})")
    void save(SetmealDish setmealDish);

    /**
     * 根据套餐id查询有无菜品属于禁用状态
     * @return
     */
    Integer countOfStopDish(Long id);

    /**
     * 根据菜品id查询所属套餐中有无启用中的套餐
     * @param id
     * @return
     */
    Integer countOfStartSetmealByDishId(Long id);

    /**
     * 查询启用套餐数量
     * @param ids
     * @return
     */
    Integer countOfStartSetmeal(List<Long> ids);

    /**
     * 删除相关套餐的菜品关联数据
     * @param ids
     */
    void deleteBySetmealId(List<Long> ids);

    /**
     * 根据setmeal的id查询相应的菜品信息
     * @param id
     * @return
     */
    @Select("select * from setmeal_dish where setmeal_id = #{id}")
    List<SetmealDish> selectBySetmealId(Long id);
}
